//###########################################################################
//
// FILE:    hw_dma.h
//
// TITLE:   Definitions for the DMA registers.
//
//###########################################################################
// $TI Release: F28004x Support Library v1.06.00.00 $
// $Release Date: Mon May 27 06:42:25 CDT 2019 $
// $Copyright:
// Copyright (C) 2019 Texas Instruments Incorporated - http://www.ti.com/
//
// Redistribution and use in source and binary forms, with or without 
// modification, are permitted provided that the following conditions 
// are met:
// 
//   Redistributions of source code must retain the above copyright 
//   notice, this list of conditions and the following disclaimer.
// 
//   Redistributions in binary form must reproduce the above copyright
//   notice, this list of conditions and the following disclaimer in the 
//   documentation and/or other materials provided with the   
//   distribution.
// 
//   Neither the name of Texas Instruments Incorporated nor the names of
//   its contributors may be used to endorse or promote products derived
//   from this software without specific prior written permission.
// 
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// $
//###########################################################################

#ifndef HW_DMA_H
#define HW_DMA_H

//*****************************************************************************
//
// The following are defines for the DMA register offsets
//
//*****************************************************************************
#define DMA_O_CTRL                0x0U         // DMA Control Register
#define DMA_O_DEBUGCTRL           0x1U         // Debug Control Register
#define DMA_O_PRIORITYCTRL1       0x4U         // Priority Control 1 Register
#define DMA_O_PRIORITYSTAT        0x6U         // Priority Status Register
#define DMA_O_MODE                0x0U         // Mode Register
#define DMA_O_CONTROL             0x1U         // Control Register
#define DMA_O_BURST_SIZE          0x2U         // Burst Size Register
#define DMA_O_BURST_COUNT         0x3U         // Burst Count Register
#define DMA_O_SRC_BURST_STEP      0x4U         // Source Burst Step Register
#define DMA_O_DST_BURST_STEP      0x5U         // Destination Burst Step
                                               // Register
#define DMA_O_TRANSFER_SIZE       0x6U         // Transfer Size Register
#define DMA_O_TRANSFER_COUNT      0x7U         // Transfer Count Register
#define DMA_O_SRC_TRANSFER_STEP   0x8U         // Source Transfer Step Register
#define DMA_O_DST_TRANSFER_STEP   0x9U         // Destination Transfer Step
                                               // Register
#define DMA_O_SRC_WRAP_SIZE       0xAU         // Source Wrap Size Register
#define DMA_O_SRC_WRAP_COUNT      0xBU         // Source Wrap Count Register
#define DMA_O_SRC_WRAP_STEP       0xCU         // Source Wrap Step Register
#define DMA_O_DST_WRAP_SIZE       0xDU         // Destination Wrap Size
                                               // Register
#define DMA_O_DST_WRAP_COUNT      0xEU         // Destination Wrap Count
                                               // Register
#define DMA_O_DST_WRAP_STEP       0xFU         // Destination Wrap Step
                                               // Register
#define DMA_O_SRC_BEG_ADDR_SHADOW  0x10U        // Source Begin Address Shadow
                                               // Register
#define DMA_O_SRC_ADDR_SHADOW     0x12U        // Source Address Shadow
                                               // Register
#define DMA_O_SRC_BEG_ADDR_ACTIVE  0x14U        // Source Begin Address Active
                                               // Register
#define DMA_O_SRC_ADDR_ACTIVE     0x16U        // Source Address Active
                                               // Register
#define DMA_O_DST_BEG_ADDR_SHADOW  0x18U        // Destination Begin Address
                                               // Shadow Register
#define DMA_O_DST_ADDR_SHADOW     0x1AU        // Destination Address Shadow
                                               // Register
#define DMA_O_DST_BEG_ADDR_ACTIVE  0x1CU        // Destination Begin Address
                                               // Active Register
#define DMA_O_DST_ADDR_ACTIVE     0x1EU        // Destination Address Active
                                               // Register

//*****************************************************************************
//
// The following are defines for the bit fields in the DMACTRL register
//
//*****************************************************************************
#define DMA_CTRL_HARDRESET        0x1U         // Hard Reset Bit
#define DMA_CTRL_PRIORITYRESET    0x2U         // Priority Reset Bit

//*****************************************************************************
//
// The following are defines for the bit fields in the DEBUGCTRL register
//
//*****************************************************************************
#define DMA_DEBUGCTRL_FREE        0x8000U      // Debug Mode Bit

//*****************************************************************************
//
// The following are defines for the bit fields in the PRIORITYCTRL1 register
//
//*****************************************************************************
#define DMA_PRIORITYCTRL1_CH1PRIORITY  0x1U         // Ch1 Priority Bit

//*****************************************************************************
//
// The following are defines for the bit fields in the PRIORITYSTAT register
//
//*****************************************************************************
#define DMA_PRIORITYSTAT_ACTIVESTS_S  0U
#define DMA_PRIORITYSTAT_ACTIVESTS_M  0x7U         // Active Channel Status Bits
#define DMA_PRIORITYSTAT_ACTIVESTS_SHADOW_S  4U
#define DMA_PRIORITYSTAT_ACTIVESTS_SHADOW_M  0x70U        // Active Channel Status Shadow
                                               // Bits

//*****************************************************************************
//
// The following are defines for the bit fields in the MODE register
//
//*****************************************************************************
#define DMA_MODE_PERINTSEL_S      0U
#define DMA_MODE_PERINTSEL_M      0x1FU        // Peripheral Interrupt and Sync
                                               // Select
#define DMA_MODE_OVRINTE          0x80U        // Overflow Interrupt Enable
#define DMA_MODE_PERINTE          0x100U       // Peripheral Interrupt Enable
#define DMA_MODE_CHINTMODE        0x200U       // Channel Interrupt Mode
#define DMA_MODE_ONESHOT          0x400U       // One Shot Mode Bit
#define DMA_MODE_CONTINUOUS       0x800U       // Continuous Mode Bit
#define DMA_MODE_DATASIZE         0x4000U      // Data Size Mode Bit
#define DMA_MODE_CHINTE           0x8000U      // Channel Interrupt Enable Bit

//*****************************************************************************
//
// The following are defines for the bit fields in the CONTROL register
//
//*****************************************************************************
#define DMA_CONTROL_RUN           0x1U         // Run Bit
#define DMA_CONTROL_HALT          0x2U         // Halt Bit
#define DMA_CONTROL_SOFTRESET     0x4U         // Soft Reset Bit
#define DMA_CONTROL_PERINTFRC     0x8U         // Interrupt Force Bit
#define DMA_CONTROL_PERINTCLR     0x10U        // Interrupt Clear Bit
#define DMA_CONTROL_ERRCLR        0x80U        // Error Clear Bit
#define DMA_CONTROL_PERINTFLG     0x100U       // Interrupt Flag Bit
#define DMA_CONTROL_TRANSFERSTS   0x800U       // Transfer Status Bit
#define DMA_CONTROL_BURSTSTS      0x1000U      // Burst Status Bit
#define DMA_CONTROL_RUNSTS        0x2000U      // Run Status Bit
#define DMA_CONTROL_OVRFLG        0x4000U      // Overflow Flag Bit

//*****************************************************************************
//
// The following are defines for the bit fields in the BURST_SIZE register
//
//*****************************************************************************
#define DMA_BURST_SIZE_BURSTSIZE_S  0U
#define DMA_BURST_SIZE_BURSTSIZE_M  0x1FU        // Burst Transfer Size

//*****************************************************************************
//
// The following are defines for the bit fields in the BURST_COUNT register
//
//*****************************************************************************
#define DMA_BURST_COUNT_BURSTCOUNT_S  0U
#define DMA_BURST_COUNT_BURSTCOUNT_M  0x1FU        // Burst Transfer Size
#endif
